/*

This file is part of roomyak.

Copyright (C) 2008 Pixecur Technologies Incorporated (Esotera).
Visit Esotera at http://www.esoteras3.com
 
roomyak is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 3, or (at your option)
any later version.
 
roomyak is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
General Public License for more details.
 
You should have received a copy of the GNU General Public License
along with roomyak; see the file COPYING.  If not, write to 
Pixecur Technologies, 213-31 Peet Street, St. John's, NL, A1B 3W8. 
 
Linking this library statically or dynamically with other modules is
making a combined work based on this library.  Thus, the terms and
conditions of the GNU General Public License cover the whole
combination.
 
*/

package com.datasentinel.util.concurrent;

import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.ReentrantLock;
import java.util.logging.Level;
import java.util.logging.Logger;

@SuppressWarnings("serial")
public class NamedReentrantLock extends ReentrantLock
{
	final static Level LOGGER_LEVEL = Level.FINER;
	
	private String name;
	public String getName()
	{
		return name;
	}

	private String context;
	private Logger logger;
	
	public NamedReentrantLock(String name, String context, Logger logger, boolean fair)
	{
		super(fair);
		this.name = name;
		this.context = context;
		this.logger = logger;
	}
	
	
	@Override
	public void lock()
	{
		if (name != null)
			logger.log(LOGGER_LEVEL, this.name + ".LOCK(-><-); " + context + " -  Thread: [" + Thread.currentThread().getName() + "] #" + Thread.currentThread().getId());
		super.lock();
	}
	
	@Override
	public void unlock()
	{
		if (name != null)
			logger.log(LOGGER_LEVEL, this.name + ".UNLOCK(<- ->); " + context + " -  Thread: [" + Thread.currentThread().getName() + "] #" + Thread.currentThread().getId());
		super.unlock();
	}
	
	@Override
	public boolean tryLock()
	{
		boolean result = super.tryLock();
		if (name != null)
			logger.log(LOGGER_LEVEL, this.name + ".TRY_LOCK(>?<) = " + result + "; " + context + " -  Thread: [" + Thread.currentThread().getName() + "] #" + Thread.currentThread().getId());
		return result;
	}
	
	@Override
	public Condition newCondition()
	{
		return new NamedCondition(this, super.newCondition(), logger);
	}
}
